

# I<sup>2</sup>C, Nonvolatile Memory, Dual 1024 Position Digital potentiometers

# Preliminary Technical Data

AD5255

#### **FEATURES**

AD5255 Dual, 1024 Position Resolution
10K and 50K Ohm Terminal Resistance
Linear or Log taper Settings
Increment/Decrement Commands, Push Button Command
I<sup>2</sup>C Compatible 2-Wire Digital Interface
+3 to +5V Single Supply Operation
±2.5V Dual Supply Operation
Nonvolatile Memory Preset
14 bytes of general purpose nonvolatile memory

#### **APPLICATIONS**

Mechanical Potentiometer Replacement Instrumentation: Gain, Offset Adjustment Programmable Voltage to Current Conversion Programmable Filters, Delays, Time Constants Line Impedance Matching Power Supply Adjustment DIP Switch Setting

### **GENERAL DESCRIPTION**

The AD5255 is a dual channel, digitally controlled variable resistor (VR) with resolutions of 1024 positions. This device performs the same electronic adjustment function as a potentiometer or variable resistor. The AD5255's versatile programming via a Micro Controller allows multiple modes of operation and adjustment. The basic mode of adjustment is the increment and decrement from the present setting of the Wiper position setting (RDAC) register. An internal scratch pad RDAC register can be moved UP or DOWN, one step of the nominal

terminal resistance between A-and-B. This linearly changes the wiper to B terminal resistance ( $R_{WB}$ ) by one position segment of the device's end-to-end resistance ( $R_{AB}$ ). For non-linear changes in wiper setting a left/right shift command adjusts levels in 6dB steps for sound and light alarm applications. In the direct program mode a predetermined setting of the RDAC register can be loaded directly from the micro controller. The third mode allows the RDAC register to be refreshed with the present nonvolatile data previously stored in the EEMEM register. When changes are made to the RDAC register to establish a new wiper position, the value of the setting can be saved into the EEMEM by executing an EEMEM save operation. Once settings are saved in the EEMEM register, these values will always be transferred to the wiper position (RDAC) register at system power ON by the internal preset strobe and it can be accessed externally as well.

The AD5255 is available in the thin TSSOP-16 package. All parts are guaranteed to operate over the extended industrial temperature range of -40°C to +85°C.

#### FUNCTIONAL BLOCK DIAGRAMS



AD5255

ELECTRICAL CHARACTERISTICS 25K, 250K OHM VERSIONS (VDD = +3V±10% or +5V±10% and VSS=0V,

 $V_A = +V_{DD}$ ,  $V_B = 0V$ ,  $-40^{\circ}C < T_A < +85^{\circ}C$  unless otherwise noted.) **Conditions Parameter Symbol** Min Typ<sup>1</sup> Max Units DC CHARACTERISTICS RHEOSTAT MODE Specifications apply to all VRs Resistor Differential NL<sup>2</sup> R<sub>WB</sub>, V<sub>A</sub>=NC R-DNL -1  $\pm 1/4$ +1 LSB Resistor Nonlinearity<sup>2</sup> R-INL R<sub>WB</sub>, V<sub>A</sub>=NC -2 +2 LSB  $\pm 1/2$ Nominal resistor tolerance  $\Delta R$  $T_A = 25$ °C,  $V_{AB} = V_{DD}$ , Wiper  $(V_W) = No$  connect -30 30 % Resistance Temperature Coefficent  $R_{AB}/\Delta T$ V<sub>AB</sub> = V<sub>DD</sub>, Wiper (V<sub>W</sub>) = No Connect 50 ppm/°C 50 Wiper Resistance  $\mathsf{R}_\mathsf{W}$  $I_W = 1 \text{ V/R}, V_{DD} = +5 \text{ V}$ 100 Ω  $\mathsf{R}_\mathsf{W}$ 200 Wiper Resistance  $I_W = 1 \text{ V/R}, V_{DD} = +3 \text{ V}$ Ω DC CHARACTERISTICS POTENTIOMETER DIVIDER MODE Specifications apply to all VRs Ν 10 Bits Integral Nonlinearity<sup>3</sup> INL 2  $\pm 1/2$ +2 LSB Differential Nonlinearity<sup>3</sup> DNL LSB 1  $\pm 1/4$ +1 Voltage Divider Temperature Coefficent Code = Half-scale  $\Delta V_W/\Delta T$ 15 ppm/°C Full-Scale Error  $V_{\text{WFSF}}$ Code = Full-scale 3 -1 +0 LSB  $\mathrm{V}_{\mathrm{WZSE}}$ Zero-Scale Error Code = Zero-scale 0 +1 +3 LSB **RESISTOR TERMINALS**  $V_{A,B,W} \\$ ٧ Voltage Range<sup>4</sup>  $V_{\text{SS}} \\$  $V_{DD}$ Capacitance<sup>5</sup> Ax, Bx f = 1 MHz, measured to GND, Code = Half-scale 45 pF  $C_{A,B}$ Capacitance<sup>5</sup> Wx  $C_W$ f = 1 MHz, measured to GND, Code = Half-scale 60 pF  $V_A = V_B = V_{DD}/2$ Common-mode Leakage Current<sup>7</sup> 0.01 1 μΑ  $I_{CM}$ **DIGITAL INPUTS & OUTPUTS** Input Logic High with respect to GND 0.3•V<sub>DD</sub> ٧  $V_{IH}$ Input Logic Low  $V_{IL}$ with respect to GND 0.7•V<sub>DD</sub> ٧ Output Logic High  $V_{OH}$  $R_{PULL-UP} = 2.2K\Omega$  to +5V 4.9 ٧ Output Logic High  $V_{OH}$  $I_{OH} = 40 \mu A$ ,  $V_{LOGIC} = +5 V$ V  $\rm V_{\rm OL}$ Output Logic Low  $I_{OL}$  = 1.6mA,  $V_{LOGIC}$  = +5V 0.4 V Input Current  $I_{IL}$  $V_{IN} = 0V \text{ or } V_{DD}$ ±1 μΑ Input Capacitance<sup>5</sup>  $\mathsf{C}_\mathsf{IL}$ 5 pF **POWER SUPPLIES** Single-Supply Power Range  $V_{DD}$  $V_{SS} = 0V$ 2.7 5.5 ٧ **Dual-Supply Power Range**  $V_{DD}/V_{SS}$  $V_{SS} = 0V$ +22 ±2.7 V Positive Supply Current  $V_{IH} = V_{DD}$  or  $V_{IL} = GND$ 2 10 uА  $I_{DD}$ **Programming Mode Current**  $V_{IH} = V_{DD}$  or  $V_{IL} = GND$ 15 I<sub>DD(PG)</sub> mΑ Read Mode Current  $V_{IH} = V_{DD}$  or  $V_{IL} = GND$ 650 I<sub>DD(READ)</sub> μΑ **Negative Supply Current**  $I_{SS}$  $V_{IH} = V_{DD}$  or  $V_{IL} = GND$ ,  $V_{DD} = 2.5V$ ,  $V_{SS} = -2.5V$ 10 μΑ Power Dissipation<sup>6</sup>  $P_{\text{DISS}}$  $V_{IH} = V_{DD}$  or  $V_{II} = GND$ 0.05 mW Power Supply Sensitivity **PSS**  $\Delta V_{DD}$  = +5V ±10% 0.002 0.01 %/% DYNAMIC CHARACTERISTICS5,7 Bandwidth 3dB BW\_25K  $R = 10K\Omega$ 600 KHz  $\mathsf{THD}_\mathsf{W}$  $V_A = 1Vrms$ ,  $V_B = 0V$ , f=1KHz0.003 **Total Harmonic Distortion** % V<sub>W</sub> Settling Time V<sub>A</sub>= VDD, V<sub>B</sub>=0V, 50% of final value  $t_S$ 25K / 250K 0.6/3/6 μs Resistor Noise Voltage  $R_{WB} = 5K\Omega$ , f = 1KHz9 nV√Hz  $e_{N\_WB}$ Crosstalk  $C_T$ V<sub>A</sub> = V<sub>DD</sub>, V<sub>B</sub> = 0V, Measue V<sub>W</sub> with adjacent VR making full scale change -65 dΒ

### ELECTRICAL CHARACTERISTICS 25K , 250K OHM VERSIONS (VDD = +3V±10% to +5V±10% and VSS=0V,

 $V_A = +V_{DD}$ ,  $V_B = 0V$ ,  $-40^{\circ}C < T_A < +85^{\circ}C$  unless otherwise noted.)

| Parameter                                           | Symbol          | Conditions                                           | Min | Typ <sup>1</sup> | Max | Units |
|-----------------------------------------------------|-----------------|------------------------------------------------------|-----|------------------|-----|-------|
| INTERFACE TIMING CHARACTERISTIC                     | S applies to    | all parts(Notes 5,8)                                 |     |                  |     |       |
| SCL Clock Frequency                                 | $f_{SCL}$       |                                                      | 0   |                  | 400 | KHz   |
| t <sub>BUF</sub> Bus free time between STOP & START | <b>t</b> 1      |                                                      | 1.3 |                  |     | μs    |
| t <sub>HD;STA</sub> Hold Time (repeated START)      | $t_2$           | After this period the first clock pulse is generated | 0.6 |                  |     | μs    |
| t <sub>LOW</sub> Low Period of SCL Clock            | t <sub>3</sub>  |                                                      | 1.3 |                  |     | μs    |
| t <sub>HIGH</sub> High Period of SCL Clock          | <b>t</b> 4      |                                                      | 0.6 |                  |     | μs    |
| t <sub>SU;STA</sub> Setup Time For START Condition  | <b>t</b> 5      |                                                      | 0.6 |                  |     | μs    |
| t <sub>HD;DAT</sub> Data Hold Time                  | t <sub>6</sub>  |                                                      | 0   |                  | 0.9 | μs    |
| t <sub>SU:DAT</sub> Data Setup Time                 | $t_7$           |                                                      | 100 |                  |     | ns    |
| t <sub>F</sub> Fall Time of both SDA & SCL signals  | t <sub>8</sub>  | . 1                                                  |     |                  | 300 | ns    |
| t <sub>R</sub> Rise Time of both SDA & SCL signals  | t <sub>9</sub>  |                                                      |     |                  | 300 | ns    |
| t <sub>SU;STO</sub> Setup time for STOP Condition   | t <sub>10</sub> | - K.                                                 | 0.6 |                  |     | μs    |
| Store to Nonvolatile EEMEM Save Time9               | t <sub>12</sub> | Applies to Command 2 <sub>H</sub> , 3 <sub>H</sub>   |     |                  | 25  | ms    |
| RDY Rise to CS Fall                                 | t <sub>15</sub> | 1011                                                 |     |                  |     | ns    |
| Preset Pulse Width                                  | <b>t</b> PR     |                                                      | 50  |                  |     | ns    |

#### NOTES:

- Typicals represent average readings at  $+25^{\circ}$ C and  $V_{DD}$  = +5V.
- Resistor position nonlinearity error R-INL is the deviation from an ideal value measured between the maximum resistance and the minimum resistance wiper positions. R-DNL measures the
- Nestative position in initial part of the last the deviation for the last value and the last value of the last value of
- Resistor terminals A,B,W have no limitations on polarity with respect to each other.
- Guaranteed by design and not subject to production test.
- $P_{DISS}$  is calculated from ( $I_{DD} \times V_{DD}$ =+5V).
- All dynamic characteristics use  $V_{DD} = +5V$ .
- See timing diagram for location of measured values. All input control voltages are specified with ta=tr=2.5ns(10% to 90% of 3V) and timed from a voltage level of 1.5V. Switching
- characteristics are measured using both  $V_{DD}$  = +3V or +5V. Low only for commands 8, 9,10, 2, 3: CMD\_8 ~ 1ms; CMD\_9,10 ~0.1ms; CMD\_2,3 ~20ms





Figure 1. Timing Diagram

Data of AD5255 is accepted from the I<sup>2</sup>C bus in the following serial format:

| , | S | 0 | 1   | 0   | 1  | 1    | Α      | Α      | R/ | Α | I7 | I6               | I5 | I4  | I3 | I2 | I1          | 10 | A | X | X   | X | X | X  | D     | D    | D   | Α | D | D | D | D | D | D | D | D | Α | P |
|---|---|---|-----|-----|----|------|--------|--------|----|---|----|------------------|----|-----|----|----|-------------|----|---|---|-----|---|---|----|-------|------|-----|---|---|---|---|---|---|---|---|---|---|---|
|   |   |   |     |     |    |      | D<br>1 | D<br>0 | W  |   |    |                  |    | . 1 |    | N' | 1           | 1  | 7 | ^ | . 6 | 3 |   | ė. | 1 0   | 9    | 8   |   | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |   |
|   | İ |   | Sla | ave | Ad | dres | s B    | yte    |    |   |    | Instruction Byte |    |     |    | (  | Data Byte 1 |    |   |   |     |   |   | Da | ata l | Byte | e 0 | • |   |   |   |   |   |   |   |   |   |   |

Where:

S = Start Condition

P = Stop Condition

 $\mathbf{A} = Acknowledge$ 

 $\mathbf{X} = \text{Don't Care}$ 

**AD1**, **AD0** = Package pin programmable address bits

 $R/\overline{W}$ = Read Enable at High and Write Enable at Low

**I7 - I1** = Instruction bits

O2, O1 = Output logic pin latched values

**D9 - D0** = 10 Data Bits



Figure 2. Complete Serial Transmission

AD5255

## **Absolute Maximum Rating** ( $T_A = +25$ °C, unless

### **Ordering Guide**

| Model        | #CHs/<br>k Ohm | Temp<br>Range | Package<br>Description | Package<br>Option |
|--------------|----------------|---------------|------------------------|-------------------|
| AD5255BRU25  | X2/25          | -40/+85°C     | TSSOP-16               | RU-16             |
| AD5255BRU250 | X2/250         | -40/+85°C     | TSSOP-16               | RU-16             |

The AD5255 contains x,xxx transistors.

Die size: x' mil x y' mil, z' sq. mil

### **AD5255 PIN CONFIGURATION**



### **AD5255 PIN FUNCTION DESCRIPTION**

|   | ADS        | 233 I IIN   | FUNCTION DESCRIPTION                                                                                                                                                     |
|---|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   | <u>#</u> N | <u>Vame</u> | Description                                                                                                                                                              |
|   | 1          | SCL         | Serial Clock Input                                                                                                                                                       |
|   | 2          | SDA         | Serial Address & Data Input/Output                                                                                                                                       |
|   | 3          | AD0         | Programmable address input 0 for multiple package decoding. Bits AD0 and AD1 provide 4 possible addresses.                                                               |
|   | 4          | GND         | Ground pin, logic ground reference                                                                                                                                       |
|   | 5          | $V_{SS}$    | Negative Supply. Connect to zero volts for single supply applications.                                                                                                   |
|   | 6          | A1          | A terminal of RDAC1.                                                                                                                                                     |
| 9 | 7          | W1          | Wiper terminal of RDAC1,<br>ADDR(RDAC1) = $0_H$ .                                                                                                                        |
|   | 8          | B1          | B terminal of RDAC1.                                                                                                                                                     |
|   | 9          | B2          | B terminal of RDAC2.                                                                                                                                                     |
|   | 10         | W2          | Wiper terminal of RDAC2,<br>ADDR(RDAC2) = $1_{\text{H}}$ .                                                                                                               |
|   | 11         | A2          | A terminal of RDAC2.                                                                                                                                                     |
|   | 12         | $V_{DD}$    | Positive Power Supply Pin. Should be ≥ the input-logic HIGH voltage.                                                                                                     |
|   | 13         | WP          | Write Protect Pin. Prevents any changes to the present EEMEM contents when active low.                                                                                   |
|   | 14         | PR          | Hardware over ride preset pin. Refreshes the scratch pad register at active low with current contents of the EEMEM register. Factory default loads midscale $512_{10}$ . |
|   | 15         | AD1         | Programmable address input 1 for multiple package decoding. Bits AD0 and AD1 provide 4 possible addresses.                                                               |
|   | 16         | RDY         | Ready. Active-high open drain output. Identifies completion of commands 2, 3, 8, 9, 10.                                                                                  |

AD5255

### **OPERATIONAL OVERVIEW**

The AD5255 digital potentiometer is designed to operate as a true variable resistor replacement device for analog signals that remain within the terminal voltage range of  $V_{SS} < V_{TERM} < V_{DD}$ . The basic voltage range is limited to a  $V_{DD}$ -  $V_{SS} < 5.5$ V. Control of the digital potentiometer allows both scratch pad register (RDAC register) changes to be made, as well as a finite number (10,000) of permanent electrically erasable memory (EEMEM) register operations. The EEMEM update process takes approximately 20.2ms, during this time the shift register is locked preventing any changes from taking place. The RDY pin flags the completion of this EEMEM save. The EEMEM retention is designed to last 10 years without refresh. The scratch pad register can be changed incrementally by using the software controlled Increment/Decrement instruction or the

the software controlled Increment/Decrement instruction or the Shift Left/Right instruction command. Alternately the scratch pad register can be programmed with any position value using the standard I<sup>2</sup>C serial interface mode by loading the representative data word. The scratch pad register can be loaded with the current contents of the nonvolatile EEMEM register under program control.

At system power ON the default value of the scratch pad memory is the last value saved in the EEMEM register. The factory EEMEM preset value is midscale  $512_{10}$ . The serial input data register uses a 32-bit slave address/instruction/data WORD. The write-protect ( $\overline{\text{WP}}$ ) pin provides a hardware EEMEM protection feature disabling any changes of the present EEMEM contents.

#### SERIAL DATA INTERFACE

The AD5255 employs a two-wire I<sup>2</sup>C serial interface requiring only two I/O lines of a standard microprocessor port. Key features of this interface include:

- Read & Write capability to all registers
- Direct parallel refresh of all RDAC wiper registers from mirrored EEMEM registers
- Increment & Decrement instructions for each RDAC wiper register
- Left & right Bit Shift of all RDAC wiper registers to achieve 6dB level changes
- Permanent storage of the present scratch pad RDAC register values into the mirrored EEMEM register
- 32 bits of user addressable electrical-erasable memory

Figure 1 shows the timing diagram for signals on the wire bus. The 2-wire bus can have several devices attached in addition to the AD5255. The two bus lines (SDA and SCL) must be high when the bus is not in use. When in use, the port bits are toggled to generate the appropriate signals for SDA and SCL. For I<sup>2</sup>C applications, two pull up resistors are required at both the SDA and SCL pins to VDD.

The AD5255 can operate SCL of up to 400KHz. A master device sends information to the AD5255 by transmitting the AD5255's address over the bus and then transmitting the desired information. Each transmission consists of a START condition, the AD5255's programmable slave address, an instruction byte, 2 data bytes consist of 10 data bits, and a STOP condition.

The address byte, instruction byte, and data bytes are transmitted between the START and STOP conditions. The state of SDA is allowed to change only if SCL is low, with the exceptions at START and STOP conditions. SDA must remain stable and is sampled ( read or write depends upon the state of  $R/\overline{W}$ ) when SCL is high. Data is transmitted in 8-bit bytes.

#### The START and STOP Conditions

When the bus is not in use, both SCL and SDA must be high. A bus master signals the beginning of a transmission with a START condition by transitioning SDA from high to low while SCL is high (Figure 3). When the master has finished communicating with the slave, it issues a STOP condition by transitioning SDA from low to high while SCL is high. The bus is then free for another transmission.



Figure 3.START and STOP Conditions

#### The Slave Address

The AD5255's slave address is seven bits long (Figure 4). The first five bits (MSBs) of the slave address have been factory programmed to 01011. The state of the AD5255 inputs AD0 and AD1 determine the final two bits of the 7-bit slave address, These input pins may be connected to VDD or GND, or may be actively driven by TTL or CMOS logic levels. There are four possible addresses for the AD5255, and therefore a maximum of four such devices may be on the bus at the same time. The eighth bit (LSB) in the slave address byte is for read write purpose. Active high allows data to be read back from the input register. Active low allows data to be written to the input register. The AD5255 watches the bus continuously, waiting for a START condition followed by its slave address. When it recognizes its slave address, it is ready to accept data.



Figure 4. Slave Address and RM Byte

The Instruction Byte
.....
The Data Bytes

AD5255

Table 1. AD5255 Instruction/Operation Truth Table

| Slave Address & R/W Byte        | Instruction Byte        | Data Byte 1 | Data Byte 0 | Operation |
|---------------------------------|-------------------------|-------------|-------------|-----------|
| B31 B24                         | B23 B16                 | B15 B8      | B7 B0       |           |
| AD6 AD5 AD4 AD3 AD2 AD1 AD0 R/W | I7 I6 I5 I4 I3 I2 I1 I0 | X D8        | D7 D0       |           |
| 0 1 0 1 1 0 0 0                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 0                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 0                 | 1                       | X X         | X X         |           |
| 0 1 0 1 1 0 0 1                 | 1                       | X X         | X X         |           |

#### NOTES:

- Form the Forming non-volatile EEMEM register.

  The increment, decrement and shift commands ignore the contents of the shift register Data Byte 0. 1. The RDAC register is a volatile scratch pad register

#### **Latched Digital Outputs**

A pair of digital outputs, O1 & O2, are available in the AD5255 and it provides a nonvolatile logic 0 or logic 1 setting. O1 & O2 are standard CMOS logic outputs shown in figure 5. These outputs are ideal to replace functions often provided by DIP switches. In addition, they can be used to drive other standard CMOS logic controlled parts that need an occasional setting change.



Figure 5. Logic Outputs O1 & O2.

#### **Detail Potentiometer Operation**

The actual structure of the RDAC is designed to emulate the performance of a mechanical potentiometer. The RDAC contains a string of connected resistor segments, with an array of analog switches that act as the wiper connection to several points along the resistor array. The number of points is the resolution of the device. For example, the AD5255 emulates 1024 connection points with 1024 equal resistance,  $R_s$ , allowing it to provide better than 0.5% set-ability resolution. Figure 6 provides an equivalent diagram of the connections between the three terminals that make up one channel of the RDAC. The switches  $SW_A$  and  $SW_B$  will always be ON while one of the switches SW(0) to  $SW(2^N-1)$  will be ON one at a time depends upon the resistance step decoded from the data. The total resistance of the active switches makes up the wipe resistance,  $R_W$ .



#### Figure 6. Equivalent RDAC structure

# PROGRAMMING THE VARIABLE RESISTOR Rheostat Operation

The nominal resistance of the RDAC between terminals A and B are available with values of  $10K\Omega$  and  $50K\Omega$ . The final digits of the part number determine the nominal resistance value, e.g.,  $10K\Omega = 10$  and  $50K\Omega = 50$ . The nominal resistance ( $R_{AB}$ ) of the AD5255 VR has 1024 contact points accessed by the wiper terminal, plus the B terminal contact. The 10-bit data word in the RDAC latch is decoded to select one of the 1024 possible settings. The wiper's first connection starts at the B terminal for data 00<sub>H</sub>. This B-terminal connection has a wiper contact resistance of  $50\Omega$ . The second connection (10K $\Omega$  part) is the first tap point located at  $60\Omega$ [= $R_{AB}$ (nominal resistance)/1024 +  $R_{W}$  = 10 $\Omega$ +50 $\Omega$ )] for data 01<sub>H</sub>. The third connection is the next tap point representing  $20+50=70\Omega$  for data  $02_H$ . Each LSB data value increase moves the wiper up the resistor ladder until the last tap point is reached at  $10040\Omega$ . The wiper does not directly connect to the B terminal. See figure 6 for a simplified diagram of the equivalent RDAC circuit.

The general transfer equation, which determines the digitally programmed output resistance between Wx and Bx, is:

$$R_{WB}(Dx) = (Dx)/2^{N*}R_{AB} + R_{W}$$
 eqn.

Where N is the resolution of the VR, Dx is the data contained in the RDACx latch, and  $R_{AB}$  is the nominal end-to-end resistance.

For example, when  $V_B\!=\!0V$  and A–terminal is open circuit, the following output resistance values will be set by the corresponding RDAC latch codes (applies to the 10-bit,  $10K\Omega$  potentiometers):

| D     | R <sub>WB</sub> | Output State                          |
|-------|-----------------|---------------------------------------|
| (DEC) | $(\Omega)$      |                                       |
|       |                 |                                       |
| 1023  | $10040\Omega$   | Full-Scale                            |
| 512   | $5050\Omega$    | Mid-Scale                             |
| 1     | $60\Omega$      | 1 LSB                                 |
| 0     | $50\Omega$      | Zero-Scale (Wiper contact resistance) |

Note that in the zero-scale condition a finite wiper resistance of  $50\Omega$  is present. Care should be taken to limit the current flow between W and B in this state to a maximum value of 5mA to avoid degradation or possible destruction of the internal switch contact.



Figure 7. Symmetrical RDAC Operation

Like the mechanical potentiometer the RDAC replaces, the AD5255 part is totally symmetrical. The resistance between the wiper W and terminal A also produces a digitally controlled resistance  $R_{WA}.$  Figure 7 shows the symmetrical programmability of the various terminal connections. When these terminals are used the B–terminal should be tied to the wiper. Setting the resistance value for  $R_{WA}$  starts at a maximum value of resistance and decreases as the data loaded in the latch is increased in value. The general transfer equation for this operation is:

$$R_{WA}(Dx) = (2^{N}-Dx)/2^{N}*R_{AB} + R_{W}$$
 eqn. 2

where N is the resolution of the VR, Dx is the data contained in the RDACx latch, and  $R_{AB}$  is the nominal end-to-end resistance. For example, when  $V_A = 0V$  and B-terminal is tied to the wiper W the following output resistance values will be set by the corresponding RDAC latch codes (applies to 10-bit,  $10K\Omega$  potentiometers):

| D     | R <sub>WA</sub> | Output State |
|-------|-----------------|--------------|
| (DEC) | $(\Omega)$      |              |
|       |                 |              |
| 1023  | 60              | Full-Scale   |
| 128   | 5050            | Mid-Scale    |
| 1     | 10040           | 1 LSB        |
| 0     | 10050           | Zero-Scale   |

The typical distribution of  $R_{AB}$  from channel-to-channel matches within  $\pm 1\%$ . However device to device matching is process lot dependent having a  $\pm 30\%$  variation. The change in  $R_{AB}$  with temperature has a 50 ppm/°C temperature coefficient.

# PROGRAMMING THE POTENTIOMETER DIVIDER Voltage Output Operation

The digital potentiometer easily generates an output voltage proportional to the input voltage applied to a given terminal. For example connecting A-terminal to +5V and B-terminal to ground produces an output voltage at the wiper which can be

any value starting at zero volts up to 1 LSB less than +5V. Each LSB of voltage is equal to the voltage applied across terminal AB divided by the  $2^N$  position resolution of the potentiometer divider. The general equation defining the output voltage with respect to ground for any given input voltage applied to terminals AB is:

$$V_{W}(Dx) = Dx/2^{N} * V_{AB} + V_{B}$$

Operation of the digital potentiometer in the divider mode results in more accurate operation over temperature. Here the output voltage is dependent on the ratio of the internal resistors and not the absolute value; therefore, the drift reduces to 15ppm/°C.

### ESD PROTECTION CIRCUITS



Figure 8A. Equivalent Digital Input ESD Protection



Figure 8B. Equivalent Digital Output ESD Protection

Figure 8 shows the equivalent ESD protection circuit for digital pins. Figure 9 shows the equivalent analog-terminal protection circuit for the variable resistors.

## **AD5255**



Figure 9. Equivalent VR-Terminal ESD Protection

#### **TEST CIRCUITS**

Figures 10 to 15 define the test conditions used in the product specification's table.



Figure 10. Potentiometer Divider Nonlinearity error test circuit (INL, DNL)



Figure 11. Resistor Position Nonlinearity Error (Rheostat Operation; R-INL, R-DNL)



Figure 12. Wiper Resistance test Circuit



Figure 13. Power supply sensitivity test circuit (PSS, PSSR)



Figure 14. Inverting Gain test Circuit



Figure 15. Non-Inverting Gain test circuit



Figure 16. Gain Vs Frequency test circuit



Figure 17. Incremental ON Resistance Test Circuit



Figure 18. Common Mode Leakage current test circuit

# TYPICAL PERFORMANCE GRAPHS TBD

#### **OUTLINE DIMENSIONS**

Dimensions shown in inches and (mm)

#### 16-Lead TSSOP (RU-16)

